package o16climbstairs;

/**
 * @author shkstart
 * @create 2022-01-12-17:27
 * 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。
 * 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢？
 */
public class ClimbStairs {

    public static void main(String[] args) {
        int i = climbStairs(3);
        System.out.println(i);
    }


    public static int climbStairs(int n) {

        int pre1 = 1, pre2 = 1, res = 0;
        if (n == 0 || n == 1) {
            return 1;
        }
        for (int i = 2; i <= n; i++) {
            res= pre1 + pre2;
            pre2 = pre1;
            pre1 = res;
        }

        return res;

    }

}
